package com.lqk.interpreter.experss;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.HashMap;


/**
 * 基本介绍
 * 	1) 在编译原理中，一个算术表达式通过词法分析器形成词法单元，而后这些词法
 * 	单元再通过语法分析器构建语法分析树，最终形成一颗抽象的语法分析树。这
 * 	里的词法分析器和语法分析器都可以看做是解释器
 * 	2) 解释器模式（Interpreter Pattern）：是指给定一个语言(表达式)，定义它的文法
 * 	的一种表示，并定义一个解释器，使用该解释器来解释语言中的句子(表达式)
 * 	3) 应用场景
 * 	• 应用可以将一个需要解释执行的语言中的句子表示为一个抽象语法树 • 一些重复出现的问题可以用一种简单的语言来表达 • 一个简单语法需要解释的场景
 * 	4) 这样的例子还有，比如编译器、运算表达式计算、正则表达式、机器人等
 *
 * 解释器模式的注意事项和细节
 * 	1) 当有一个语言需要解释执行，可将该语言中的句子表示为一个抽象语法树，就可以
 * 	考虑使用解释器模式，让程序具有良好的扩展性
 * 	2) 应用场景：编译器、运算表达式计算、正则表达式、机器人等
 * 	3) 使用解释器可能带来的问题：解释器模式会引起类膨胀、解释器模式采用递归调用
 * 	方法，将会导致调试非常复杂、效率可能降低.
 */
public class ClientTest {

	public static void main(String[] args) throws IOException {
		// TODO Auto-generated method stub
		String expStr = getExpStr();
		HashMap<String, Integer> var = getValue(expStr);
		Calculator calculator = new Calculator(expStr);
		System.out.println("运算结果：" + expStr + "=" + calculator.run(var));
	}

	// 获得表达式
	public static String getExpStr() throws IOException {
		System.out.print("请输入表达式：");
		return (new BufferedReader(new InputStreamReader(System.in))).readLine();
	}

	// 获得值映射
	public static HashMap<String, Integer> getValue(String expStr) throws IOException {
		HashMap<String, Integer> map = new HashMap<>();

		for (char ch : expStr.toCharArray()) {
			if (ch != '+' && ch != '-') {
				if (!map.containsKey(String.valueOf(ch))) {
					System.out.print("请输入" + String.valueOf(ch) + "的值：");
					String in = (new BufferedReader(new InputStreamReader(System.in))).readLine();
					map.put(String.valueOf(ch), Integer.valueOf(in));
				}
			}
		}

		return map;
	}
}

